$(function () {
  const layer = layui.layer;

  // 1 创建裁剪区域
  // 获取裁剪区域对象
  var $image = $("#image");
  // 配置选项
  const options = {
    // 纵横比
    aspectRatio: 1,
    // 指定预览的区域
    preview: ".img-preview",
  };
  // 创建裁剪区域
  $image.cropper(options);

  //2 点击上传更换图片
  $("#choseImg").on("click", function () {
    $("#file").click();
  });

  // 3 更换图片 添加change 改变事件
  $("#file").on("change", function (e) {
    // 获取到当前点击的图片
    let filelist = e.target.files;
    // 判断拿到的下标是否为零，是的话就没有选择文件
    if (filelist.length === 0) {
      return layer.msg("请选择图片");
    }

    // 拿到用户选择的文件
    let file = e.target.files[0];
    // 根据选择的文件创建URL地址
    var newImgURL = URL.createObjectURL(file);
    // 创建重新选择图片的裁剪区域、
    $image.cropper("destroy").attr("src", newImgURL).cropper(options);
  });

  // 4 点击确定上传头像
  $("#uploadImg").on("click", function () {
    let dataURL = $image
      .cropper("getCroppedCanvas", {
        width: 100,
        heigth: 100,
      })
      .toDataURL("image/png");
    $.ajax({
      method: "POST",
      url: "/my/update/avatar",
      data: {
        avatar: dataURL,
      },
      success: function (res) {
        if (res.status !== 0) {
          return layer.msg("更新头像失败");
        }
        layer.msg("更新头像成功");
        // 调用父页面中的方法，重新渲染用户的头像和用户的信息
        window.parent.getUserInfo();
      },
    });
  });
});
